"""
Case Type   : bugfix
Case Name   : 兼容B库支持列名大小写不同时的修改
Create At   : 2025/6/11
Owner       : liu-tong-8848
Description :
    1、建表
    2、rename列名，修改为大小写不同的同名列
    3、清理环境
Expect      :
    1、成功
    2、成功
    3、成功
History     :
"""

import os
import unittest

from yat.test import Node
from yat.test import macro

from testcase.utils.Common import Common
from testcase.utils.CommonSH import CommonSH
from testcase.utils.Constant import Constant
from testcase.utils.Logger import Logger


class BugFix(unittest.TestCase):
    def setUp(self):
        self.log = Logger()
        self.common = Common()
        self.sh_primary = CommonSH('PrimaryDbBmode')
        self.user_node = Node('PrimaryDbBmode')
        self.constant = Constant()

    def test_dolphin(self):
        self.log.info(f'----{os.path.basename(__file__)} start----')
        text = '----step1:建表；expect:成功----'
        self.log.info(text)
        sql_cmd = f"drop table if exists t_fixed_105;create table t_fixed_105(ABC int);"
        self.log.info(sql_cmd)
        sql_res = self.sh_primary.execut_db_sql(sql_cmd)
        self.log.info(sql_res)
        self.assertIn(self.constant.CREATE_TABLE_SUCCESS, sql_res, '执行失败' + text)
        self.assertIn(self.constant.DROP_TABLE_SUCCESS, sql_res, '执行失败' + text)

        text = '----step2:rename列名，修改为大小写不同的同名列；expect:成功----'
        self.log.info(text)
        sql_cmd = "alter table t_fixed_105 change ABC abc int;"
        self.log.info(sql_cmd)
        sql_res = self.sh_primary.execut_db_sql(sql_cmd)
        self.log.info(sql_res)
        self.assertIn(self.constant.ALTER_TABLE_MSG, sql_res, '执行失败' + text)
        sql_cmd = "alter table t_fixed_105 rename abc to ABC;"
        self.log.info(sql_cmd)
        sql_res = self.sh_primary.execut_db_sql(sql_cmd)
        self.log.info(sql_res)
        self.assertIn(self.constant.ALTER_TABLE_MSG, sql_res, '执行失败' + text)

    def tearDown(self):
        text = '----step3:清理环境；expect:成功----'
        self.log.info(text)
        sql_cmd = f"drop table if exists t_fixed_105;"
        self.log.info(sql_cmd)
        sql_res = self.sh_primary.execut_db_sql(sql_cmd)
        self.assertIn(self.constant.DROP_TABLE_SUCCESS, sql_res, '执行失败' + text)
        self.log.info(f'----{os.path.basename(__file__)} end-----')
